# Universidade do Minho - Departamento de Eletrónica Industrial

# Sistemas Digitais - Laboratórios TP5 - Flip-flops e Máquinas de Estados

Duração máxima: 3 aulas.

Os alunos devem entregar a preparação prévia ao docente no início da 1ª aula de cada trabalho (imediatamente ao entrar na sala), com a resolução de todas as questões indicadas a sublinhado no guia. O atraso na entrega implicará uma penalização na nota. A mesma resolução deve estar anotada no logbook.

### Antes de realizar o trabalho, os alunos devem ter estudado os seguintes tópicos:

- 1) Diferenças entre entradas assíncronas e síncronas;
- 2) Distinção entre uma latch e um flip-flop;
- 3) Funcionamento de flip-flops D, T e JK;
- 4) Diferenças entre lógica combinacional e lógica sequencial;
- 5) Construção de diagramas de estado e de tabelas de estado, de transição e de excitação.

### Durante a realização do trabalho, os alunos devem:

- 1) Realizar as montagens indicadas no guia;
- 2) Registar no *logbook* todos os valores calculados e medidos.

#### Depois de realizar o trabalho na totalidade, os alunos devem:

- 1) Ter verificado experimentalmente os tópicos propostos;
- 2) Ser capazes de identificar e evitar problemas de bounce em circuitos sequenciais;
- 3) Ser capazes de distinguir um flip-flop ativado por flanco ascendente (positive-edge-triggered) de um flip-flop ativado por flanco descendente (negative-edge-triggered);
- 4) Ser capazes de projetar circuitos sequenciais básicos.

#### Elementos de estudo:

- 1) Slides de Sistemas Digitais.
- 2) John F. Wakerly, "Digital Design, Principles and Practices", Prentice Hall, 2000.

## Procedimento

Obs.: Todas as entradas dos componentes digitais devem ser sempre ligadas a pontos que forneçam tensão (e.g. Vcc, GND, um interruptor ou uma saída), ou seja, nenhuma entrada deve ser deixada em aberto, caso contrário, o mais provável é que o componente não funcione conforme esperado. Como sabe, também não deve aplicar uma tensão a uma saída, pois irá provocar um curto-circuito, pelo que deve sempre consultar o datasheet do componente para identificar as entradas e saídas antes de utilizá-lo.

1 - Quando uma saída provém diretamente de um interruptor normal, esta é afetada por problemas de vibração mecânica (bounce) quando o contacto se fecha. Isso significa que, caso a saída deste interruptor seja utilizada como entrada de relógio (clock) de um circuito sequencial, irão ocorrer múltiplas transições do clock para cada acionamento do interruptor (como ilustrado na figura 1a), em vez de somente uma transição de cada vez, como seria desejável, pelo que o circuito não irá funcionar conforme esperado.

Obs.:. Conforme foi visto num trabalho prático anterior, a figura 1a apresenta uma representação do circuito interno de um interruptor do Digital Lab (por exemplo, P4), que se encontra montado no interior deste equipamento, pelo que NÃO DEVE MONTAR ESSE CIRCUITO, visto que o sinal P4 indicado na figura já se encontra disponível.

De forma a garantir que a mudança de nível lógico se faça sem oscilações, torna-se necessário utilizar um circuito chamado "circuito de *debounce*" como o apresentado na figura 1b, que é baseado numa *latch* S' R'.

Com este circuito, em vez de usar um interruptor mecânico (como o P4), deve usar um fio (como mostra a figura 1b) em que uma extremidade é ligada à massa e a outra faz contacto alternadamente com os terminais das resistências que estão ligados às entradas das portas NAND (pontos X e Y).

Indique o que acontece com o valor da saída OUT do circuito de debounce quando a extremidade livre do fio efetua a seguinte sequência:

- a) Faz contacto com o ponto Y.
- b) Deixa de fazer contacto com qualquer ponto.
- c) Passa a fazer contacto com o ponto X.
- d) Deixa de fazer contacto com qualquer ponto.



Fig. 1a - Interruptor mecânico.

Fig. 1b - Circuito de debounce.

Monte o circuito de *debounce* e teste o seu funcionamento, com auxílio de um LED do Digital Lab na sua saída.

Obs.: Não desmonte o circuito de *debouce*. Este circuito (ou equivalente) deve ser utilizado no exercício 3 e todos os exercícios seguintes que necessitem de *clock*.

**2 -** Um circuito integrado 74112 contém dois flip-flops JK *negative-edge-triggered* com entradas assíncronas PRESET e CLEAR, como mostra a Figura 2.

### Responda às seguintes perguntas:

- a) Quais devem ser os níveis lógicos que deve aplicar nas entradas PRESET e CLEAR para que o flip-flop opere de forma normal, ou seja, que a saída Q responda de forma síncrona às entradas de *clock*. J e K?
- b) Quais devem ser os níveis lógicos nas entradas PRESET e CLEAR para realizar a operação de SET assíncrono do flip-flop (ou seja, fazer Q = 1)?
- c) Quais devem ser os níveis lógicos nas entradas PRESET e CLEAR para realizar a operação de RESET assíncrono do flip-flop (ou seja, fazer Q = 0)?
- d) Preencha a Tabela 1 com os valores que as entradas J e K devem tomar para possibilitar as transições indicadas do estado atual (Q) para o estado seguinte (Q\*). Utilize *don't care* quando for apropriado.



Fig. 2. Flip-flop JK.

| Tabela 1. |    |   |   |  |  |  |  |  |  |  |
|-----------|----|---|---|--|--|--|--|--|--|--|
| Q         | Q* | J | K |  |  |  |  |  |  |  |
| 0         | 0  |   |   |  |  |  |  |  |  |  |
| 0         | 1  |   |   |  |  |  |  |  |  |  |
| 1         | 0  |   |   |  |  |  |  |  |  |  |
| 1         | 1  |   |   |  |  |  |  |  |  |  |

<u>3 - Projete um circuito contador ascendente/descendente de 2 bits utilizando flip-flops JK.</u> O circuito deve possuir uma entrada C que controla a contagem da seguinte forma:

Além disso, o circuito deve ter uma outra entrada, chamada L, que funciona da seguinte forma: quando L = 0, o valor inicial da contagem (Q1 = Q0 = 0, neste caso) é carregado nos flip-flops, de forma assíncrona. Quando L = 1 o circuito efetua a contagem.

- a) Apresente uma tabela de transição/excitação que relacione como entradas: o estado atual (Q1 e Q0) e a entrada C; e como saídas: o estado seguinte (Q1\* e Q0\*) e os valores correspondentes nas entradas dos flip-flops (J1, K1, J0 e K0).
- b) Com base na tabela da alínea anterior, determine as equações de excitação dos flip-flops JK em função de Q1, Q0 e C, com recurso a mapas de Karnaugh.
- c) Determine os sinais a inserir nas entradas assíncronas  $\overline{\text{PRESET}}$  e  $\overline{\text{CLEAR}}$  para satisfazer os requisitos deste problema.
- d) Desenhe o diagrama esquemático do circuito em conformidade com as regras indicadas nos trabalhos práticos anteriores.

Monte o circuito e teste o seu funcionamento **utilizando o circuito de** *debounce* montado no exercício 1 como entrada de *clock*.

Para comprovar a utilidade do circuito de *debounce*, após ter o circuito a funcionar conforme esperado, **observe o que ocorre quando substitui este circuito**, **na entrada de** *clock*, **por um interruptor normal do Digital Lab**, como por exemplo P7.

Considere no problema seguinte que A e B são os números mecanográficos (de 5 dígitos decimais) dos dois elementos do grupo, com A < B, sendo A1 e B1 os dígitos decimais mais à esquerda dos respetivos números, A5 e B5 os dígitos mais à direita. Caso o grupo tenha apenas um elemento, o número A é obtido da parte inteira de B/2, em que B é o número mecanográfico do aluno.

**4 -** Utilizando **flip-flops D** disponíveis em circuitos integrados 7474 e portas lógicas auxiliares, projete um circuito detetor de sequência que ative uma saída OPEN sempre que detetar a sequência de 4 bits desejada (S) na sua entrada BIT.

A **sequência S** deve ser derivada do valor do **dígito A3** do número mecanográfico A, através fórmula S = A3+1.

Por exemplo, para A = 75423, A3 = 4, pelo que S = 5, ou 0101 em binário. Neste caso, temos como exemplo a seguinte correspondência entre valores de entrada e saída da máquina de estados:

| BIT  | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
|------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| OPEN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |

O estado inicial da máquina de estados deve corresponder aos 3 dígitos menos significativos do dígito B3 do número mecanográfico B. Por exemplo, no caso em que B3 = 9 (1001) o estado inicial corresponde a Q2 = 0, Q1 = 0 e Q0 = 1.

A atribuição de estados para os demais estados da máquina fica ao critério do grupo.

Além disso, o circuito deve ter uma outra entrada, chamada LOAD/SHIFT, que funciona da seguinte forma: quando LOAD/SHIFT = 0, o estado inicial é carregado nos flip-flops, de forma assíncrona. Quando LOAD/SHIFT = 1 o circuito funciona em conformidade com as instruções anteriores.

- a) Construa o diagrama de estados para a sequência de 4 bits do seu grupo.
- b) Efetue a atribuição de estados tendo em consideração o valor do dígito B3.
- c) Apresente a tabela de transição/saída para o problema, relacionando como entradas: o estado atual (Q2, Q1 e Q0) e a entrada BIT; e como saídas: o estado seguinte (Q2\*, Q1\* e Q0\*) e a saída da máquina de estados (OPEN).
- d) Com base na tabela da alínea anterior, determine as equações de excitação dos flip-flops D e a equação de saída, com recurso a mapas de Karnaugh.
- e) Determine os sinais a inserir nas entradas assíncronas  $\overline{PRESET}$  e  $\overline{CLEAR}$  dos flipflops para satisfazer os requisitos deste problema.
- f) Desenhe o diagrama esquemático do circuito.

Monte o circuito e teste o seu funcionamento.